//################################################################################
// MIT License
// Copyright (c) 2024 ZhangYihua
//
// Change Logs:
// Date           Author       Notes
// 2020-06-24     ZhangYihua   first version
//
// Description  : 
//################################################################################

module rw_reg #(
parameter           DW                      = 1,
parameter           INI                     = {DW{1'b0}}
) ( 
input                                       rst_cfg_n,
input                                       clk,

input                                       cs,
input                                       we,
input               [DW-1:0]                wd,

output  reg         [DW-1:0]                q
);

//################################################################################
// define local varialbe and localparam
//################################################################################

//################################################################################
// main
//################################################################################

always@(posedge clk or negedge rst_cfg_n) begin
    if (rst_cfg_n==1'b0) begin
        q <=`U_DLY INI;
    end else begin
        if ((cs==1'b1) && (we==1'b1))
            q <=`U_DLY wd;
        else
            ;
    end
end

//################################################################################
// ASSERTION
//################################################################################

`ifdef CBB_ASSERT_ON
// synopsys translate_off


// synopsys translate_on
`endif

endmodule
